package com.example.dense_rack_server.mapper;

import cn.hutool.json.JSONObject;
import com.example.dense_rack_server.entity.MyUser;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Select;

import java.util.List;
import java.util.Map;

/**
 * <p>
 *  Mapper 接口
 * </p>
 *
 * @author  张彬 
 * @since 2025-03-03
 */
public interface MyUserMapper extends BaseMapper<MyUser> {

    /**
     * 获取角色
     */
    Map<String,Object> getUserRoleName(String userName);


    /**
     * 通过用户名获取用户
     */
    @Select("select * from my_user t where t.user_name = #{userName}")
    MyUser getUserByName(String userName);

    /**
     * 分页处理
     * 获取用户列表 left join
     */
    List<Map<String, Object>> getAllUser(Map<String, Object> map);
    /**
     * 分页处理
     * 获取用户列表数量 left join
     */
    int getAllUserCount(Map<String, Object> map);

    /**
     * 分页处理
     * 获取部门下用户
     */
    List<Map<String, Object>> getDeptUser(Map<String, Object> map);

    /**
     * 分页处理
     * 获取部门下用户数量
     */
    int getDeptUserCount(String deptId);

    /**
     * 修改用户数据
     */
    int updateUser(JSONObject data);

    /**
     * 用户详情
     */
    Map<String, Object> getUserDetail(String userId);

    /**
     * 获取所有下级用户
     */
    List<Object> getBelowUser(String deptId);
}
